草庐IT

python - SQLAlchemy:具有多个 where 条件的 SQL 表达式

全部标签

ruby - 正则表达式用逗号和空格分割字符串,但忽略带连字符的单词?

我需要一个正则表达式来用逗号和/或空格分隔字符串,但忽略带连字符的单词——最好的方法是什么?所以,例如——我想要这个……"foobar,zap-foo,baz".split(/[\s]+/)返回["foo","bar","zap-foo","baz"]但是当我这样做时,它包括像这样的逗号......["foo","bar,","zap-foo,","baz"] 最佳答案 "foobar,zap-foo,baz".split(/[\s,]+/) 关于ruby-正则表达式用逗号和空格分割字符

ruby - 如何更新 Ruby on Rails 3 中的多个列?

出于好奇,有没有办法这样说...user.update_column(:field1,true)user.update_column(:field2,true)...在RubyonRails中在一行中?据我所知,update_columns方法不存在... 最佳答案 您可以按如下方式使用update_all:User.where(:id=>user.id).update_all({:field1=>true,:field2=>true})这将生成以下更新语句(mysql):UPDATEusersSETfield1=1,field2=

Ruby 使用正则表达式从字符串中提取数据

我正在做一些网络抓取,这是数据的格式Sr.No.Course_CodeCourse_NameCreditGradeAttendance_Grade我收到的实际字符串是以下形式1CA727PRINCIPLESOFCOMPILERDESIGN3AM我感兴趣的是Course_Code、Course_Name和Grade,在此示例中,这些值将是Course_Code:CA727Course_Name:PRINCIPLESOFCOMPILERDESIGNGrade:A有什么方法可以让我使用正则表达式或其他技术轻松提取此信息,而不是手动解析字符串。我在1.9模式下使用jruby。

ruby-on-rails - RSpec:通过正则表达式匹配字符串数组

我正在使用rspec测试我的模型的验证,并期待一条错误消息。但是,消息的确切文本可能会发生变化,所以我想更宽容一点,只检查部分消息。由于Spec::Matchers::include方法只适用于字符串和集合,我目前正在使用这个结构:@user.errors[:password].any?{|m|m.match(/istooshort/)}.shouldbe_true这可行,但对我来说似乎有点麻烦。是否有更好(即更快或更像ruby​​)的方法来检查数组是否包含正则表达式的字符串,或者是否有一个rspec匹配器可以做到这一点? 最佳答案

ruby - 为什么条件包含停止在 Jekyll 中工作,除非我添加非空白字符?

我的基于Jekyll的网站突然停止运行,包括GoogleAnalytics脚本block。昨天还能用(脚本block在所有页面上),但是今天,在我上传新帖子后,脚本block从所有页面统一消失。我在GitHub页面上托管我的网站,因此为了排除故障,我想在我的本地计算机上重现该问题。原来我在本地机器上运行的是旧版本的Ruby和Jekyll,所以我更新了Ruby并安装了GitHubPagesGem为了确保我的本地环境与GitHub页面匹配:geminstallgithub-pages这使我能够重现该问题。现在,即使我跑了jekyllserve--safeAnalytics脚本block未包

ruby-on-rails - 如何在 Gemfile 中使用条件

我的Gemfile中有这些组:group:development,:testdogem'sqlite3'endgroup:productiondogem'mysql'end开发机没有安装MySQL,这也是我只在生产组列出MySQL的原因。但是当我尝试在开发机器上运行Rails时,我得到了这个:$>RAILS_ENV=development./script/railsCouldnotfindgem'mysql(>=0,runtime)'inanyofthegemsourceslistedinyourGemfile.显然我可以通过安装MySQL来解决这个问题,但我想知道正确的解决方案而不是

ruby - 正则表达式 "empty range in char class error"

我的代码中有一个正则表达式,用于匹配url的模式并抛出错误:/^(http|https):\/\/([\w-]+\.)+[\w-]+([\w-.\/?%&=]*)?$/错误是“字符类错误中的空范围”。我发现原因在([\w-.\/?%&=]*)?部分。Ruby似乎将\w-.中的-识别为范围运算符,而不是文字-。给dash加上escape后问题解决。但原来的正则表达式在我同事的机器上运行良好。我们使用相同版本的osx、rails和ruby:Ruby版本是ruby1.9.3p194,rails是3.1.6,osx是10.7.5。在我们将代码部署到我们的Heroku服务器之后,一切都运行良好。

ruby - 具有可选查询参数的 Sinatra

我想创建一个带有可选查询参数的SinatraAPI路由。我可以按如下方式添加查询参数%r{^/mysql/data/(?)/start_time=(?\w*)/?}但是上面route对应的route是像"/mysql/data/:name/start_time=:start_time"我需要查询参数作为可选参数并以URL格式声明。例如:/mysql/data/:name?start_time=:start_time&end_time=:end_time在Sinatra中有什么方法可以做到这一点吗? 最佳答案 引自Sinatra文档:

ruby - 如何转义 Ruby 中的字符串以防止 SQL 注入(inject)? (无导轨)

我只是想知道我们如何在Ruby中转义SQL查询(字符串)以防止SQL注入(inject)。请注意我没有使用Rails框架。谢谢。 最佳答案 如果可能,请使用RubyDBI模块,而不是尝试引用您的字符串,而是使用参数化的准备查询,如下所示:dbh=DBI.connect("DBI:Mysql:test:localhost","testuser","testpass")sth=dbh.prepare("INSERTINTOpeople(id,name,height)VALUES(?,?,?)")File.open("people.txt

ruby-on-rails - 将多个字符串传递给 ruby​​ starts_with?

我有这个代码ifself.name.starts_with?('Bronze')||self.name.starts_with?('Silver')||self.name.starts_with?('Gold')有没有一种方法可以一次传递所有这些字符串而不是大量的OR,因为我可能必须对此进行扩展? 最佳答案 String#start_with?接受任意数量的参数。您不需要使用||。'Silvermedal'.start_with?('Bronze','Silver','Gold')#=>true'Hellomedal'.start_